草庐IT

php - 友谊系统SQL结构与查询

全部标签

ruby-on-rails - 是否有 Ruby 数据库迁移 gem,可帮助您将内容从旧结构移动到新结构?

是否有任何Rubygem/库可以帮助您从旧的数据库结构迁移到新的结构?ActiveRecord迁移在跟踪新数据库结构方面做得很好,但我想知道是否有什么可以帮助您将整个遗留数据库迁移到新结构:transfer_from(:source_table=>'person',:destination_table=>'dudes_and_dudets')dofrom:name,:to=>:full_namefrom:dob,:to=>:agedo|dob|#thiswould,forexample,loadtheresult(Date.today-dob)/60/60/24/365#ofthebl

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

sql - 用于 250K+ 字符串的通配符搜索的 Fast(er) 方法

我在MySQL数据库中有一个英语词典,其中只有超过250K个条目,我正在使用一个简单的ruby​​前端在字符串的开头使用通配符来搜索它。到目前为止,我一直这样做:SELECT*FROMwordsWHEREwordLIKE'_e__o'甚至SELECT*FROMwordsWHEREwordLIKE'____s'我总是知道单词的确切长度,但除了一个字符之外的所有字符都可能是未知的。这比糖蜜慢,比没有前导通配符的类似查询慢大约15倍,因为无法使用该列的索引。我尝试了几种方法来缩小搜索范围。例如,我添加了26个额外的列,其中包含每个单词的单个字母计数,并首先使用这些列来缩小搜索范围。我也试过按

ruby-on-rails - "require File.dirname(__FILE__)"-- 如何安全地解除文件系统依赖?

我正在使用的一些Ruby库使用这样的require语句:requireFile.dirname(__FILE__)+'/specification_helper.rb'lib_dir=File.expand_path(File.join(File.dirname(__FILE__),"lib"))requireFile.join(File.dirname(__FILE__),'lib/tools','version')requireFile.expand_path(File.join(File.dirname(__FILE__),'datautils','conn'))这种格式不会使您

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G

ruby - 复杂的graphviz树结构

我正在尝试使用graphviz创建树结构。我愿意手动编写graphviz代码或使用ruby​​-graphvizgemforruby​​。鉴于下图,任何人都可以提供有关必要代码的任何见解吗?忽略线条不是直的……当graphviz构建图形时它们应该是。当线相交时,我也愿意接受点/点。我玩过ruby​​-graphviz和家谱类......这让我了解了其中的一部分,但我真的需要所有的线都是直的并且以直角相交并且开箱即用代码似乎没有这样做。代码应该足够通用,以允许“C”框也有子项,并允许“A”下有更多的子项。颜色无关紧要...示例可以排除任何着色。http://docs.google.com

sql - Rails SQL COUNT N+1 效率低下

我有一个博客。在我的索引页面上,我拉入了所有博客文章。对于每篇博客文章,我都会计算该文章的评论数。这会导致N+1问题。我的查询如下所示:SELECT"blog_posts".*FROM"blog_posts"WHERE("blog_posts"."published"='t')ORDERBYpublished_atDESCSELECT"users".*FROM"users"WHERE("users"."id"IN(1,2,3))SELECTCOUNT(*)FROM"blog_comments"WHERE("blog_comments".blog_post_id=10)SELECTCOU

ruby - 如何在 ActiveRecord 中执行 LIKE % 查询?

我正在尝试查找一些包含特定字符串的项目。如果我这样做:MyModel.where("descriptionLIKE?",keyword)它将生成一个完全匹配的查询。我想让它生成一个LIKE%keyword%查询。我该怎么做? 最佳答案 like_keyword="%#{keyword}%"MyModel.where("descriptionLIKE?",like_keyword) 关于ruby-如何在ActiveRecord中执行LIKE%查询?,我们在StackOverflow上找到一

ruby - 在 Sinatra 之上构建 MVC 结构

我正在学习Sinatra,我想知道是否有人知道使用Sinatra为项目制作MVC结构的好方法。我有一些想法,但对我来说它们似乎太麻烦了。 最佳答案 Sinatra已经是“VC”——您的View与您的路由(Controller)分离。如果愿意,您可以选择将其分成多个文件;有关更多信息,请参阅此答案(我的):UsingSinatraforlargerprojectsviamultiplefiles要添加“M”(模型),请选择一个数据库框架。有些人喜欢ActiveRecord.有些人喜欢DataMapper.还有更多可供您选择。我个人非常